<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>ES6 块级作用域????</title>
  </head>
  <body>
    <button>按钮一</button>
    <button>按钮二</button>
    <button>按钮三</button>
    <button>按钮四</button>
    <button>按钮五</button>
    <button>按钮六</button>
    <script>
      //1.作用域：变量在什么范围你可以使用
      {
        var name = "LHC";
        console.log(name);
      }
      console.log(name);
      //2.没有块级作用域引起的问题 if 的块级

      //3.没有块级作用域引起的问题 for的块级
      var btns = document.getElementsByTagName("button");
      //   for (var i = 0; i < btns.length; i++) {
      //     btns[i].addEventListener("click", function () {
      //       console.log("第" + i + "个按钮被点击");
      //     });
      //   }

      //闭包可以解决上述问题？函数是一个作用域
      for (var i = 0; i.btns.length; i++) {
        (function (num) {
          btns[i].addEventListener("click", function () {
            console.log("第" + num + "个按钮被点击");
          });
        })(i);
      }

      //ES6:
      for (let i = 0; i < btns.length; i++) {
        btns[i].addEventListener("click", function () {
          console.log("第" + i + "个按钮被点击");
        });
      }
    </script>
  </body>
</html>
